/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package edu.upc.clase.demo.dao.impl;

import edu.upc.clase.demo.dao.CategoriaDao;
import edu.upc.clase.demo.dao.UsuarioDao;
import edu.upc.clase.demo.entity.Categoria;
import edu.upc.clase.demo.entity.Usuario;
import java.util.List;
import javax.sql.DataSource;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.simple.SimpleJdbcDaoSupport;
import org.springframework.stereotype.Repository;

/**
 *
 * @author operador
 */

@Repository
public class CategoriaDaoImpl extends SimpleJdbcDaoSupport implements CategoriaDao {

    private static Logger log = LoggerFactory.getLogger(UsuarioDaoImpl.class);

    @Autowired
    public CategoriaDaoImpl(DataSource dataSource) {
        log.info("Asignando el dataSource");
        setDataSource(dataSource);
    }

    /*
     *  Query => para obtener listas
     *  QueryforObject => para obtener un solo objeto, en caso de mas de 1 da excepcion
     */
    
    @Override
    public List<Categoria> buscarTodos() {
        return getSimpleJdbcTemplate().query(
                "select id,nombre from categorias",
                new BeanPropertyRowMapper<Categoria>(Categoria.class));
    }

    @Override
    public Categoria buscar(int id) {
        return getSimpleJdbcTemplate().queryForObject(
                "select id,nombre from categorias where id=?",
                new BeanPropertyRowMapper<Categoria>(Categoria.class), id);
    }
    
    @Override
    public int actualizar(Categoria c) {
        return getJdbcTemplate().update(
                "update categorias set nombre = ? where id = ?",
                c.getNombre(), c.getId());
    }
    
    @Override
    public int eliminar(Categoria c) {
        return getJdbcTemplate().update(
                "delete from categorias where id = ?",
                c.getId());
    }

}
